Use gtk_show_uri_on_window() in GtkLabel
authorEmmanuele Bassi <ebassi@gnome.org>
Thu, 16 Feb 2017 00:24:57 +0000 (00:24 +0000)
committerBastien Nocera <hadess@hadess.net>
Thu, 16 Feb 2017 15:37:55 +0000 (16:37 +0100)
Avoid the deprecated gtk_show_uri(), and allow activating link in
sandboxed applications.

https://bugzilla.gnome.org/show_bug.cgi?id=778726

demos/gtk-demo/links.c
gtk/gtklabel.c

index c896656ffd356f42758d37af639c859a167d361a..dcd7ba517489f5b6bd2beb771ffaa292c91fb3aa 100644 (file)
@@ -1,7 +1,7 @@
 /* Links
  *
  * GtkLabel can show hyperlinks. The default action is to call
- * gtk_show_uri() on their URI, but it is possible to override
+ * gtk_show_uri_on_window() on their URI, but it is possible to override
  * this with a custom handler.
  */
 
index bc5ae4c3ef0aa5cd2c0765c1b1ab0481e30a4b38..268f9c84de24b92f7c8a6ce069cf43053207bf07 100644 (file)
@@ -748,7 +748,7 @@ gtk_label_class_init (GtkLabelClass *class)
      *
      * The signal which gets emitted to activate a URI.
      * Applications may connect to it to override the default behaviour,
-     * which is to call gtk_show_uri().
+     * which is to call gtk_show_uri_on_window().
      *
      * Returns: %TRUE if the link has been activated
      *
@@ -6597,10 +6597,11 @@ gtk_label_activate_link (GtkLabel    *label,
                          const gchar *uri)
 {
   GtkWidget *widget = GTK_WIDGET (label);
+  GtkWidget *top_level = gtk_widget_get_toplevel (widget);
+  guint32 timestamp = gtk_get_current_event_time ();
   GError *error = NULL;
 
-  if (!gtk_show_uri (gtk_widget_get_screen (widget),
-                     uri, gtk_get_current_event_time (), &error))
+  if (!gtk_show_uri_on_window (GTK_WINDOW (top_level), uri, timestamp, &error))
     {
       g_warning ("Unable to show '%s': %s", uri, error->message);
       g_error_free (error);